<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <p>hash test</p>
  <button id="btn1">修改 hash</button>
<script>

  // 点击跳转的时候, 通过 location.hash 改变 hash 值
  // 通过监听 window 的 onhashchange 事件, 可以获得 oldURL, newURL 以及 hash 值, 来渲染对应的页面

  // 'http://127.0.0.1:8881/01-hash.html?a=100&b=20#/aaa/bbb';
  // location.protocol -> http
  // location.hostname -> 127.0.0.1
  // location.host -> 127.0.0.1:8881
  // location.port -> 8881
  // location.pathname -> 01-hash.html
  // location.search -> ?a=100&b=20
  // location.hash -> #/aaa/bbb



  // hash 变化包括:
  // 1. js 修改 url
  // 2. 手动修改 url 的 hash
  // 3. 浏览器的前进和后退
  window.onhashchange = (e) => {
    console.log('old url', e.oldURL);
    console.log('new url', e.newURL);
    console.log('hash', location.hash);
  }

  // 页面初次加载, 获取 hash
  document.addEventListener('DOMContentLoaded', () => {
    console.log('hash:', location.hash);
  });

  // js 修改 url
  document.querySelector('#btn1').addEventListener('click', e => {
    location.hash = '#/user';
  });


</script>
</body>
</html>